package com.sg.model.po;


import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.sg.framework.common.po.BaseEntity;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotNull;
import lombok.Data;
import lombok.experimental.Accessors;

import java.io.Serial;
import java.util.Date;

/**
 * 主表  有小版本，主消息已读，相关消息全部已读
 *
 * @author xxx
 */
@Data
@Accessors(chain = true)
@TableName("oms_message")   //2-5-02 消息表
public class OmsMessage extends BaseEntity {

    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * 消息ID
     */
    @TableId(value = "message_id", type = IdType.ASSIGN_UUID)
    @NotNull(message = "messageId不能为空")
    private String messageId;

    /**
     * 消息通道ID
     */
    @TableField(value = "message_channel_id")
    @NotNull(message = "消息通道ID不能为空")
    @Schema(description = "消息通道ID")
    private String messageChannelId;

    /**
     * 协同内容类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表 OMS_VIRTUAL_ORG:虚拟组织表
     */
    @TableField(value = "cooperate_content_type_code")
    @Schema(description = "协同内容类型编码")
    private String cooperateContentTypeCode;

    /**
     * 是否精品 TRUE:是 FALSE:否
     */
    @TableField(value = "is_boutique")
    @Schema(description = "是否精品")
    private String isBoutique;

    /**
     * 通道类型编码 MESSAGE_ASSISTANT:消息助手 PERSONAL_SESSION:个人会话 GROUP_SESSION:内容圈子群会话 CUSTOMER_SERVICE_SESSION:客服会话 CONTENT_COMMENT_SESSION:1111圈子内容评论会话（废弃） NOT_COMMENT_SESSION:非内容圈子评论会话 CONTENT_ORIGIN_QA_SESSION:文案助手 THIRD_QA_SESSION:独立第三方问答 ORG_GROUP:组织群 DEPT_GROUP:部门群 DEPT_IDEA_GROUP:部门想法 PERSONAL_IDEA_SESSION:个人想法 NORMAL_GROUP_SESSION:普通会话群
     */
    @TableField(value = "message_channel_type_code")
    @NotNull(message = "通道类型编码不能为空")
    @Schema(description = "通道类型编码")
    private String messageChannelTypeCode;

    /**
     * 协同内容ID
     */
    @TableField(value = "cooperate_content_id")
    @Schema(description = "协同内容ID")
    private String cooperateContentId;

    /**
     * 消息标题
     */
    @TableField(value = "message_title")
    @Schema(description = "消息标题")
    private String messageTitle;

    /**
     * 是否已处理 TRUE:是 FALSE:否
     */
    @TableField(value = "is_handle")
    @Schema(description = "是否已处理")
    private String isHandle;

    /**
     * 消息内容
     */
    @TableField(value = "message_content")
    @NotNull(message = "消息内容不能为空")
    @Schema(description = "消息内容")
    private String messageContent;

    /**
     * 消息访问链接
     */
    @TableField(value = "message_content_url")
    @NotNull(message = "消息访问链接不能为空")
    @Schema(description = "消息访问链接")
    private String messageContentUrl;

    /**
     * 协同内容名称
     */
    @TableField(value = "surface_cont_name")
    @Schema(description = "协同内容名称")
    private String surfaceContName;

    /**
     * 处理类型 NO_NEED_HANDLING:不需要处理 NEED_HANDLING:需要处理 NEED_BUSINESS_OPERATION_HANDLING:需要业务操作处理
     */
    @TableField(value = "handle_type")
    @Schema(description = "处理类型")
    private String handleType;

    /**
     * 消息使用通道类别 INTELLIGENT_STUDY:智能学习 INTELLIGENT_CUSTOMER_SERVICE:智能客服 NOTIFICATION_ANNOUNCEMENT:通知公告 CONTENT_COMMUNICATION:内容沟通 WORK_CIRCLE:工作圈 IDEA:想法
     */
    @TableField(value = "msg_channel_class_code")
    @Schema(description = "消息使用通道类别")
    private String msgChannelClassCode;

    /**
     * 消息模板标识
     */
    @TableField(value = "message_template_code")
    @NotNull(message = "消息模板标识不能为空")
    @Schema(description = "消息模板标识")
    private String messageTemplateCode;

    /**
     * 发送方是否助手 TRUE:是 FALSE:否
     */
    @TableField(value = "is_assistant")
    @NotNull(message = "发送方是否助手不能为空")
    @Schema(description = "发送方是否助手")
    private String isAssistant;

    /**
     * 媒介类型 VIDEO:视频 AUDIO:音频 FILE:文件 PIC:图片
     */
    @TableField(value = "media_type")
    @Schema(description = "媒介类型")
    private String mediaType;

    /**
     * 发送方角色 SYSTEM:第三方系统 USER:用户 ASSISTANT:助手
     */
    @TableField(value = "message_role")
    @NotNull(message = "发送方角色不能为空")
    @Schema(description = "发送方角色")
    private String messageRole;

    /**
     * 消息重要紧急度层级
     */
    @TableField(value = "message_important_level")
    @NotNull(message = "消息重要紧急度层级不能为空")
    @Schema(description = "消息重要紧急度层级")
    private Long messageImportantLevel;

    /**
     * 媒介地址
     */
    @TableField(value = "media_address")
    @Schema(description = "媒介地址")
    private String mediaAddress;

    /**
     * 引用的消息ID
     */
    @TableField(value = "reference_message_id")
    @Schema(description = "引用的消息ID")
    private String referenceMessageId;

    /**
     * 发送方就职部门ID
     */
    @TableField(value = "sender_dept_id")
    @Schema(description = "发送方就职部门ID")
    private String senderDeptId;

    /**
     * 发送方虚拟组织成员ID
     */
    @TableField(value = "sender_virtual_org_member_id")
    @Schema(description = "发送方虚拟组织成员ID")
    private String senderVirtualOrgMemberId;

    /**
     * 引用的消息内容
     */
    @TableField(value = "reference_message_content")
    @Schema(description = "引用的消息内容")
    private String referenceMessageContent;

    /**
     * 发送方就职记录ID
     */
    @TableField(value = "sender_induction_record_id")
    @Schema(description = "发送方就职记录ID")
    private String senderInductionRecordId;

    /**
     * 归属内容类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表 OMS_VIRTUAL_ORG:虚拟组织表
     */
    @TableField(value = "surface_code")
    @NotNull(message = "归属内容类型编码不能为空")
    @Schema(description = "归属内容类型编码")
    private String surfaceCode;

    /**
     * 发送方身份人员ID
     */
    @TableField(value = "sender_original_role_member_id")
    @Schema(description = "发送方身份人员ID")
    private String senderOriginalRoleMemberId;

    /**
     * 归属内容ID
     */
    @TableField(value = "entity_id")
    @NotNull(message = "归属内容ID不能为空")
    @Schema(description = "归属内容ID")
    private String entityId;

    /**
     * 发送方账号ID
     */
    @TableField(value = "sender_user_id")
    @Schema(description = "发送方账号ID")
    private String senderUserId;

    /**
     * 发送方头像地址
     */
    @TableField(value = "sender_profile_picture_address")
    @Schema(description = "发送方头像地址")
    private String senderProfilePictureAddress;

    /**
     * 主题内容类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表 OMS_VIRTUAL_ORG:虚拟组织表
     */
    @TableField(value = "theme_content_type_code")
    @Schema(description = "主题内容类型编码")
    private String themeContentTypeCode;

    /**
     * 发送方姓名
     */
    @TableField(value = "name_of_sender")
    @Schema(description = "发送方姓名")
    private String nameOfSender;

    /**
     * 主题内容ID
     */
    @TableField(value = "theme_content_id")
    @Schema(description = "主题内容ID")
    private String themeContentId;

    /**
     * 发送方虚拟形象标识
     */
    @TableField(value = "virtual_image_code")
    @Schema(description = "发送方虚拟形象标识")
    private String virtualImageCode;

    /**
     * 是否平台代操作 TRUE:是 FALSE:否
     */
    @TableField(value = "platform_replace")
    @NotNull(message = "是否平台代操作不能为空")
    @Schema(description = "是否平台代操作")
    private String platformReplace;

    /**
     * 行为类型编码
     */
    @TableField(value = "behavior_type_code")
    @NotNull(message = "行为类型编码不能为空")
    @Schema(description = "行为类型编码")
    private String behaviorTypeCode;

    /**
     * 操作时间
     */
    @TableField(value = "operate_time")
    @NotNull(message = "操作时间不能为空")
    @Schema(description = "操作时间")
    private Date operateTime;

    /**
     * 创建时间
     */
    @TableField(value = "create_time")
    @NotNull(message = "创建时间不能为空")
    @Schema(description = "创建时间")
    private Date createTime;

    /**
     * 是否作废 TRUE:是 FALSE:否
     */
    @TableField(value = "is_valid")
    @NotNull(message = "是否作废不能为空")
    @Schema(description = "是否作废")
    private String isValid;

    /**
     * 创建于空间ID
     */
    @TableField(value = "space_id")
    @NotNull(message = "创建于空间ID不能为空")
    @Schema(description = "创建于空间ID")
    private String spaceId;

    /**
     * 创建于联盟应用ID
     */
    @TableField(value = "app_id")
    @NotNull(message = "创建于联盟应用ID不能为空")
    @Schema(description = "创建于联盟应用ID")
    private String appId;
}
